草庐IT

java - JUNIT测试void方法

全部标签

ruby-on-rails - 无法从类内部访问私有(private)方法?

为什么我无法从类封装的方法中访问下面代码中的私有(private)方法check_url?classLink{:in=>[true,false]}validates:url,:presence=>true#===============================================================#=classmethods(accessiblefromoutsidewithoutaninstance)=#===============================================================classurl,:i

ruby-on-rails - 如何在ruby中动态调用类方法

假设我将模型名称保存在一个变量中:"#{class_name.singularize}"我想从另一个Controller查看为此模型定义的列。我试过了send("#{class_name.singularize}.columns")但它试图调用Page.columns作为我当前正在使用的类的方法,而不是Page类。关于如何执行此操作的任何想法? 最佳答案 使用constantize:class_name.singularize.constantize.columns 关于ruby-on-

ruby - rspec 中的依赖测试

我编写功能测试,我需要做的测试取决于之前测试的通过情况。假设我有一个按钮可以打开一个窗口,其中有一个功能。也就是说,为了检查此功能,我需要首先检查按钮的正确操作(即打开窗口或不起作用)。所以,我需要这样做,如果单击按钮时测试失败,则测试不会运行以检查功能窗口。单独编写测试-对我来说不是一种选择。我希望看到这样的内容:describe"sometests"doopen_result=nilit"shouldcheckworkbutton"doclick_to_button()open_result=window_opened?open_result.should==trueendifop

Ruby:是否有缩进 case 语句的正确方法?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭9年前。Improvethisquestion许多博客和教程在实现case语句时都有不同的缩进。关于“何时”行,每个都有不同的缩进。使用case循环时是否有缩进的最佳实践?

ruby - Rails 4 升级后格式化程序错误的未定义方法 `tagged'

我已经按照RubyScreencast指南从Rails3.2升级到Rails4。我的测试正在运行并且服务器已启动,但我在发送请求时收到错误消息:ERRORNoMethodError:undefinedmethod`tagged'for#/home/mahoni/.rvm/gems/ruby-2.0.0-p195/gems/activesupport-4.0.0/lib/active_support/tagged_logging.rb:67:in`tagged'/home/mahoni/.rvm/gems/ruby-2.0.0-p195/gems/railties-4.0.0/lib/r

ruby-on-rails - RSpec 期望接收带有数组的方法,但顺序无关紧要

假设我有方法#sum,它接受一个数组并计算所有元素的总和。我正在stub:beforedoexpect(calculation_service).toreceive(:sum?).with([1,2,3]){6}end不幸的是,我的测试服以随机顺序传递数组。由于引发了该错误:Failure/Error:subject{do_crazy_stuff!}#received:sum?withunexpectedargumentsexpected:([1,2,3])got:([3,2,1])是否可以忽略数组元素的顺序对方法调用进行stub?array_including(1,2,3)无法确保数

ruby - 在 Ruby 中,如何控制 Test::Unit 测试的运行顺序?

例如,当运行这些测试时,我想确保test_fizz总是先运行。require'test/unit'classFooTest更新:我为什么要这样做?我的想法是,某些测试(那些测试更简单、更基本的方法)的早期失败将使跟踪系统中的问题变得更容易。例如,bar的成功取决于fizz是否正常工作。如果fizz坏了,我想马上知道,因为没有必要担心bar,它也会失败,但输出要复杂得多测试结果。 最佳答案 您可以使用Test::Unit::TestCase#test_order=:defined定义测试顺序例子:gem'test-unit'#Iuse

Ruby 在没有显式包含声明的情况下在子类上执行 self.included(base) 方法?

我有许多继承自一个父类(superclass)的类。作为模块定义的父类(superclass)。模块内部是一个设置一些实例变量的self.included(base)方法。所以像这样:moduleMyModuledefself.included(base)base.instance_variable_set("@my_instance_variable",{})endendclassMySuperClassincludeMyModuleendclassClassA除非我明确地将MyModule包含在ClassA和ClassB中,否则我的实例变量将不会在这两个类中设置。有没有办法确保在每

ruby - 引用与类同名的模块中的方法

我有一个同名的类和一个模块:modulePushoverdefconfigure..endendmoduleMyModuleclassPushoverdefblahPushover.configureendendend这不起作用,因为Pushover.configure调用指向包含类。现在,一个明显的解决方法是重命名该类。但是,模块来自gem,并且类符合DSL中要求的命名约定。所以理想情况下,它们应该保持不变。我还可以创建第二个帮助程序类并通过它进行调用,但这一切看起来有点老套。我的首选解决方案是直接引用模块方法。围绕这个领域的所有现有问题似乎都在相反的方向上消除歧义——即他们想要获得

Ruby,如何创建一个 Rack::Request 用于测试目的?

我有一个库,它接受一个Rack::Request并在其上做一些事情。我想通过单元测试而不是功能测试来测试它。所以我必须自己创建一个Rack::Request实例,我该怎么做? 最佳答案 Rack本身包含一些针对Rack::Request的单元测试,您可以将它们用作起点(example)。Rack::Request.new(Rack::MockRequest.env_for("http://example.com:8080/",{"REMOTE_ADDR"=>"10.10.10.10"}))